
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl">

    <script>
        $(function () {
            //超级管理员:若是不需要选择角色,若不是显示
            var $div;//定义一个变量来接受角色选择框
            $('#admin').click(function () {
                var prop = $(this).prop('checked');
                if(prop){
                    $div = $('#role').detach();
                }else{
                    //加个弟弟(也就是还原)
                    $('#adminDiv').after($div);
                }
            })

            //页面一加载完,判断如果是超管,不需要显示角色选择框
            <#if (employee.admin)!false>
                $('#role').detach();
            </#if>

            //提交按钮
            //当为员工选择角色去了右边的时候,直接提交,只会提交点到角色,索引需要将右边所有的都选中再提交
            /*$('#submitBtn').click(function () {
                $('.selfRoles').prop('selected',true);
                $('#editForm').submit();
            })*/

            //为员工设置角色时,设置到右边时,左边则不需要显示
            var arr =[];
            $('.selfRoles > option').each(function (i,ele) {
                arr.push($(ele).val());
            })
            $('.allRoles > option').each(function (i,ele) {
                var val = $(ele).val();
                //若存在返回索引,不存在返回-1
                if($.inArray(val,arr) > -1){
                    $(ele).remove();
                }
            })


            //表单内容验证 ,使用表单验证插件,表单只能用插件的方式提交
            $('#editForm').bootstrapValidator({
                feedbackIcons: {
                    valid: 'glyphicon glyphicon-ok',
                    invalid: 'glyphicon glyphicon-remove',
                    validating: 'glyphicon glyphicon-refresh'
                },
                fields: {
                    <#if !employee??>
                        name: {
                            validators: {
                                notEmpty: {
                                    message: '用户名不能为空'
                                },
                                remote: {
                                    type: 'POST',
                                    url: '/employee/checkName.do',
                                    message: '此用户名已经存在',
                                    delay: 1000
                                }
                            }
                        },
                    </#if>
                    password:{
                        validators:{
                            notEmpty:{
                                message:"密码必填"
                            }
                        }
                    },
                    repassword:{
                        validators: {
                        notEmpty:{
                            message:"密码必填"
                        },
                        identical: {
                            field: 'password',
                            message: '两次输入的密码必须相同'
                        }}
                    },
                    email: {
                        validators: {
                            notEmpty: {
                                message: '邮箱地址不能为空'
                            },
                            emailAddress: {
                                message: '邮箱地址格式有误'
                            }
                        }
                    },
                    age:{
                        validators: {
                            between: {
                                min: 18,
                                max: 60
                            }
                        }
                    }
                }
            }).on('success.form.bv', function(e) { //表单所有数据验证通过后执行里面的代码
                //禁止原本的表单提交
                e.preventDefault();
                //设置右边的所有option为选中的状态
                $(".selfRoles option").prop('selected',true);

                $("#editForm").ajaxSubmit(function (data) {
                    if(data.success){ //用alert或者popup都可以
                        $.messager.alert("温馨提示","保存成功!1s后自动关闭")
                        window.setTimeout(function () {
                            window.location.href = "/employee/list.do";
                        },1000)
                    }else{
                        $.messager.popup(data.msg)
                    }
                })
            });
        })
    </script>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" >
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name"
                                   <#if employee??>
                                    readonly
                                   </#if>
                                   name="name" value="${(employee.name)!}" placeholder="请输入用户名">
                        </div>
                    </div>
                    <#--如果是新增就可以设置密码,编辑不显示-->
                    <#if !employee??>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <option value="-1">全部</option>
                                <#list depts as d>
                                    <option value="${d.id}">${d.name!}</option>
                                </#list>
                            </select>
                            <script>
                                $('#dept').val(${(employee.dept.id)!})
                            </script>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                            <#if (employee.admin)!false>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>

                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <#--角色选择  设置multiple可以多选-->
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                </select>
                            </div>
                            <#--选择功能键-->
                            <script>
                                function moveSelected(srcClass,targetClass) {
                                    $('.'+targetClass).append($('.'+srcClass+'>option:selected'));
                                }
                                function moveAll(srcClass,targetClass) {
                                    $('.'+targetClass).append($('.'+srcClass+'>option'));
                                }
                            </script>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#--编辑的时候需要回显角色数据-->
                                    <#list (employee.list)! as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="submit" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "../common/footer.ftl">
</div>
</body>
</html>
